package codingInterview.leetcode.editor.cn;

//请从字符串中找出一个最长的不包含重复字符的子字符串，计算该最长子字符串的长度。 
//
// 
//
// 示例 1: 
//
// 输入: "abcabcbb"
//输出: 3 
//解释: 因为无重复字符的最长子串是 "abc"，所以其长度为 3。
// 
//
// 示例 2: 
//
// 输入: "bbbbb"
//输出: 1
//解释: 因为无重复字符的最长子串是 "b"，所以其长度为 1。
// 
//
// 示例 3: 
//
// 输入: "pwwkew"
//输出: 3
//解释: 因为无重复字符的最长子串是 "wke"，所以其长度为 3。
//     请注意，你的答案必须是 子串 的长度，"pwke" 是一个子序列，不是子串。
// 
//
// 
//
// 提示： 
//
// 
// s.length <= 40000 
// 
//
// 注意：本题与主站 3 题相同：https://leetcode-cn.com/problems/longest-substring-without-
//repeating-characters/ 
// Related Topics 哈希表 字符串 滑动窗口 👍 391 👎 0

//Java：剑指 Offer 48 - 最长不含重复字符的子字符串
public class ZuiChangBuHanZhongFuZiFuDeZiZiFuChuanLcof{
    public static void main(String[] args) {
                Solution solution = new ZuiChangBuHanZhongFuZiFuDeZiZiFuChuanLcof().new Solution();
        // TO TEST
    }
    
    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public int lengthOfLongestSubstring(String s) {
        if(s.length()<2) return s.length();
        int[] position = new int[128];
        int length=s.length(), curLength =0, maxLength = 0;
        for (int i = 0; i < 128; i++) {
            position[i] =-1;
        }
        for (int i = 0; i < length; i++) {
            int prevIndex = position[s.charAt(i)]; // 上次出现的位置
            if(prevIndex<0 || i-prevIndex>curLength){ // 未出现或不在i-1的字符串中
                curLength++;
            }else{
                curLength = i-prevIndex;
            }
            position[s.charAt(i)] = i;
            maxLength = Math.max(curLength, maxLength);
        }
        return maxLength;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
